import java.util.HashMap;
import java.util.Map;
import java.util.Scanner;

public class Test2 {
    public static void main(String[] args) {
        Scanner in = new Scanner(System.in);
        // 注意 hasNext 和 hasNextLine 的区别
        while (in.hasNextInt()) { // 注意 while 处理多个 case
            int n = in.nextInt();
            in.nextLine();
            char[] cc = in.nextLine().toCharArray();
            // f表用来记录[0,i]位置之间有多少个_x字符串
            long[] f = new long[26];

            // g表用来记录[0,i]位置之间有多少个x字符
            long[] g = new long[26];

            long ret = 0;
            for (int i = 0; i < n; i++) {
                int x = cc[i] - 'a';
                ret += f[x];

                f[x] = f[x] + i - g[x];
                g[x] = g[x] + 1;
            }
            System.out.println(ret);
        }
    }
}
